## Homework04

1. (Adapted from 5.31)

The following diagram shows a snapshot of the 8 registers of the LC-3 before and after the instruction at location x1000 is executed. Fill in the bits of the instruction at location x1000.

| Register | Before | After |
|----------|--------|-------|
| R0       | x0000  | x0000 |
| R1       | x1111  | x1111 |
| R2       | x2222  | x2222 |
| R3       | x3333  | x3333 |
| R4       | x4444  | x4444 |
| R5       | x5555  | xFFF8 |
| R6       | x6666  | x6666 |
| R7       | x7777  | x7777 |

| Memory Location | Value |
|-----------------|-------|
| x1000           | 01    |

### The instruction should be 0001 101 000 1 11000.

- 2. The memory locations x3000 to x3007 contain the values as shown in the table below. Assume the memory contents below are loaded into the simulator and the PC has been set to point to location x3000. Assume that a break point has been placed to the left of the HALT instruction (i.e. at location x3006 which contains 1111 0000 0010 0101). Assume that before the program is run, each of the 8 registers has the value x0000 and the NZP bits are 010.
- a. In no more than 15 words, summarize what this program will do when the Run button is pushed in the simulator.

# R0 is x0005 at first and shifted left for the value at location x3007 times.

b. What are the contents of the PC, the 8 general purpose registers (R0-R7), and the N, Z, and P condition code registers after the program completes?

| PC    | R0    | R1    | R2    | R3    | R4    | R5    | R6    | R7    | NZP |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-----|
| x3006 | x0050 | x0000 | 010 |

c. What is the total number of CPU clock cycles that this program will take to execute until it reaches the breakpoint? Note: You should refer to the state machine (pg 702) to determine how many cycles an instruction takes. Assume each state that access memory takes 5 cycles to complete and every other state takes 1 cycle to execute. States that check for ACV also take 1 cycle to execute.

## Total cycles = 10+10+17+40+40+(11\*3+10)=160

3. What does the following program do (in 15 words or fewer)? The PC is initially at x3000.

| Memory Location | Value                |
|-----------------|----------------------|
| x3000           | 0101 000 000 1 00000 |
| x3001           | 0010 001 011111110   |
| x3002           | 0000 010 000000100   |
| x3003           | 0000 011 000000001   |
| x3004           | 0001 000 000 1 00001 |
| x3005           | 0001 001 001 000 001 |
| x3006           | 0000 111 111111011   |
| x3007           | 1111 0000 0010 0101  |

## Counts how many bits are 1 in the word at x3100

4. Prior to executing the following program, memory locations x3100 through x4000 are initialized to random values, exactly one of which is negative. The following program finds the address of the negative value, and stores that address into memory location x3050. Two instructions are missing. Fill in the missing instructions to complete the program. The PC is initially at x3000.

| Memory Location | Value                |
|-----------------|----------------------|
| x3000           | 1110 000 011111111   |
| x3001           |                      |
| x3002           |                      |
| x3003           | 0001 000 000 1 00001 |
| x3004           | 0000 111 111111100   |
| x3005           | 0011 000 001001010   |
| x3006           | 1111 0000 0010 0101  |

| x3001 | 0110 001 000 000000 | LDR R1,R0,#0 |
|-------|---------------------|--------------|
| x3002 | 0000 100 000000010  | BRn x3005    |

5. The LC-3 has just finished executing a large program. A careful examination of each clock cycle reveals that the number of executed store instructions (ST, STR, and STI) is greater than the number of executed load instructions (LD, LDR, and LDI). However, the number of memory write accesses is less than the number of memory read accesses, excluding instruction fetches. How can that be? Be sure to specify which instructions may account for the discrepancy.

A large number of LDI instructions (two read accesses) and STI instructions (one read access and one write access) could account for this discrepancy.

6. (7.2) An LC-3 assembly language program contains the instruction:

ASCII LD R1, ASCII

The label ASCII corresponds to the address x4F08. If this instruction is executed during the running of the program, what will be contained in R1 immediately after the instruction is executed?

### 0010 001 1 1111 1111, the pc offset has to be -1

7. (Adapted from 7.10) The following program fragment has an error in it. Identify the error and explain how to fix it.

|   | ADD R3, R3, #30 |
|---|-----------------|
|   | ST R3, A        |
|   | HALT            |
| Α | .BLKW 1         |

Will this error be detected when this code is assembled or when this code is run on the LC-3?

#30 is too large for a imm5, it can be fixed by executing ADD R3,R3,#15 twice.

This error will be detected when this code is assembled as it can not generate a 16 bits instruction.

8. Consider the following assembly language program:

What are the possible initial values of R1 that cause the final value in R2 to be 3?

|      | AND R2, R2, #0  |
|------|-----------------|
| LOOP | ADD R1, R1, #-3 |
|      | BRn END         |
|      | ADD R2, R2, #1  |
|      | BRnzp LOOP      |
| END  | HALT            |

# R1 can be 9, 10 or 11

9. (Adapted from 7.16) Assume a sequence of nonnegative integers is stored in consecutive memory locations, one integer per memory location, starting at location x4000. Each integer has a value between 0 and 30,000 (decimal). The sequence terminates with the value -1 (i.e., xFFFF).

a. Create the symbol table entries generated by the assembler when translating the following routine into machine code:

| .ORIG x3000    |
|----------------|
| AND R4, R4, #0 |
| AND R3, R3, #0 |
| LD R0, NUMBERS |
| LDR R1, R0, #0 |
| NOT R2, R1     |
| BRz DONE       |
| AND R2, R1, #1 |
| BRz L1         |
| ADD R4, R4, #1 |
| BRnzp NEXT     |
| ADD R3, R3, #1 |
| ADD R0, R0, #1 |
| BRnzp LOOP     |
| TRAP x25       |
| .FILL x4000    |
| .END           |
|                |

| Symbol  | Address |
|---------|---------|
| LOOP    | x3003   |
| L1      | x300A   |
| NEXT    | x300B   |
| DONE    | x300D   |
| NUMBERS | x300E   |

b. What does the above program do?

# R3 counts the amount of even numbers in the list and R4 counts the amount of odd numbers.

10. Below is a segment of LC-3 assembly language program.

If the data in R1 is an unsigned integer larger than 1, what does the program do? (Hint: what is the relationship between the resulting integer in R2 and the original integer in R1?)

|      | ADD R2, R1, #0  |
|------|-----------------|
| HERE | ADD R3, R2, #-1 |
|      | AND R3, R3, R2  |
|      | BRz END         |
|      | ADD R2, R2, #1  |
|      | BRnzp HERE      |
| END  | HALT            |

# When R2 equals 2<sup>n</sup>, then the program ends. So the program finds the smallest number that is equal to or larger than the number in R1.

11.(Adapted from 7.18) The following LC-3 program compares two character strings of the same length. The source strings are in the .STRINGZ form. The first string starts at memory location x4000, and the second string starts at memory location x4100. If the strings are the same, the program terminates with the value 1 in R5; otherwise the program terminates with the value 0 in R5. Insert one instruction each at (a), (b), and (c) that will complete the program. Note: The memory location immediately following each string contains x0000.

- a) LDR R3,R1,#0
- b) **NOT R4,R4**
- b) AND R4,R4,#1

|                | 1                                                                                                                                                                                                           |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .ORIG x3000    |                                                                                                                                                                                                             |
| LD R1, FIRST   |                                                                                                                                                                                                             |
| LD R2, SECOND  |                                                                                                                                                                                                             |
| AND R0, R0, #0 |                                                                                                                                                                                                             |
|                | (a)                                                                                                                                                                                                         |
| LDR R4, R2, #0 |                                                                                                                                                                                                             |
| BRz NEXT       |                                                                                                                                                                                                             |
| ADD R1, R1, #1 |                                                                                                                                                                                                             |
| ADD R2, R2, #1 |                                                                                                                                                                                                             |
|                | (b)                                                                                                                                                                                                         |
|                | (c)                                                                                                                                                                                                         |
| ADD R3, R3, R4 |                                                                                                                                                                                                             |
| BRz LOOP       |                                                                                                                                                                                                             |
| AND R5, R5, #0 |                                                                                                                                                                                                             |
| BRnzp DONE     |                                                                                                                                                                                                             |
| AND R5, R5, #0 |                                                                                                                                                                                                             |
| ADD R5, R5, #1 |                                                                                                                                                                                                             |
| TRAP x25       |                                                                                                                                                                                                             |
| .FILL x4000    |                                                                                                                                                                                                             |
| .FILL x4100    |                                                                                                                                                                                                             |
| .END           |                                                                                                                                                                                                             |
|                | LD R1, FIRST  LD R2, SECOND  AND R0, #0  LDR R4, R2, #0  BRz NEXT  ADD R1, R1, #1  ADD R2, R2, #1  ADD R3, R3, R4  BRz LOOP  AND R5, R5, #0  BRnzp DONE  AND R5, R5, #1  TRAP x25  .FILL x4000  .FILL x4100 |

12. The data at memory address x3500 is a bit vector with each bit representing whether a certain power plant in the area is generating electricity (bit = 1) or not (bit = 0). The program counts the number of power plants that generate electricity and stores the result at x3501. However, the program contains a mistake which prevents

it from correctly counting the number of electricity generating (operational) power plants. Identify it and explain how to fix it.

# The instruction LD R2, VECTOR should be inserted after BRp CHECK to give address for STR R0, R2, #1

13. The following program does not do anything useful. However, being an electronic idiot, the LC-3 will still execute it. Without using the simulator, answer the following questions:

```
.ORIG x3000
        LD RO, Addr1
        LEA R1, Addr1
        LDI R2, Addr1
        LDR R3, R0, #-6
        LDR R4, R1, #0
        ADD R1, R1, #3
        ST R2, #5
        STR R1, R0, #3
        STI R4, Addr4
        HALT
      .FILL x300B
Addr1
       .FILL x000A
Addr2
Addr3
       .BLKW 1
Addr4
       .FILL x300D
       .FILL x300C
Addr5
        . END
```

 What will the values of registers R0 through R4 be after the LC- 3 finishes executing the ADD instruction?

# R0=x300B, R1=x300D, R2=x000A, R3=x1263, R4=x300B

 What will the values of memory locations Addr1 through Addr5 be after the LC-3 finishes executing the HALT instruction?

ADDR1=x300B, ADDR2=x000A, ADDR3=x000A, ADDR4=x300B, ADDR5=x300D